<?php

/**
 * 新闻信息实体操作类
 * @note  实现了对了新闻信息的基本增删改查工作
 * @class  XWXX
 * @file  XWXX.class.php
 * @author 赤菁风铃
 * @time  2014年04月10日 22:40:14
 * @database  SQLServer
 */

/**
 * Class _XWXX 新闻信息数据操作类
 */
class _XWXX
{
    #region 自动生成代码
    #region 构造函数
    public function __construct($data = null){
        $this->XWXX_BH = date('YmdHis').guid(); //新闻信息编号
        $this->XWLM_BH = ''; //新闻栏目编号
        $this->XWXX_BT = ''; //新闻信息标题
        $this->XWXX_ZY = ''; //新闻信息摘要
        $this->XWXX_RQ = date('Y-m-d'); //新闻信息日期
        $this->XWXX_ZT = ''; //新闻信息状态
        $this->XWXX_LX = ''; //新闻信息类型
        $this->XWXX_CLJ = ''; //新闻信息超链接
        $this->XWXX_NR = ''; //新闻信息内容
        $this->XWXX_TP = ''; //新闻信息图片
        if(!is_null($data))
        {
            if(array_key_exists('XWXX_BH',$data)) $this->XWXX_BH = $data["XWXX_BH"];
            if(array_key_exists('XWLM_BH',$data)) $this->XWLM_BH = $data["XWLM_BH"];
            if(array_key_exists('XWXX_BT',$data)) $this->XWXX_BT = $data["XWXX_BT"];
            if(array_key_exists('XWXX_ZY',$data)) $this->XWXX_ZY = $data["XWXX_ZY"];
            if(array_key_exists('XWXX_RQ',$data)) $this->XWXX_RQ = $data["XWXX_RQ"];
            if(array_key_exists('XWXX_ZT',$data)) $this->XWXX_ZT = $data["XWXX_ZT"];
            if(array_key_exists('XWXX_LX',$data)) $this->XWXX_LX = $data["XWXX_LX"];
            if(array_key_exists('XWXX_CLJ',$data)) $this->XWXX_CLJ = $data["XWXX_CLJ"];
            if(array_key_exists('XWXX_NR',$data)) $this->XWXX_NR = $data["XWXX_NR"];
            if(array_key_exists('XWXX_TP',$data)) $this->XWXX_TP = $data["XWXX_TP"];
        }
    }
    #endregion 构造函数
        
    #region 实体固有属性
    
    /**
     * 属性  新闻信息编号
     * @name  XWXX_BH
     * @type  string
     */
    public $XWXX_BH;
    
    /**
     * 属性  新闻栏目编号
     * @name  XWLM_BH
     * @type  string
     */
    public $XWLM_BH;
    
    /**
     * 属性  新闻信息标题
     * @name  XWXX_BT
     * @type  string
     */
    public $XWXX_BT;
    
    /**
     * 属性  新闻信息摘要
     * @name  XWXX_ZY
     * @type  string
     */
    public $XWXX_ZY;
    
    /**
     * 属性  新闻信息日期
     * @name  XWXX_RQ
     * @type  string
     */
    public $XWXX_RQ;
    
    /**
     * 属性  新闻信息状态
     * @name  XWXX_ZT
     * @type  string
     */
    public $XWXX_ZT;
    
    /**
     * 属性  新闻信息类型
     * @name  XWXX_LX
     * @type  string
     */
    public $XWXX_LX;
    
    /**
     * 属性  新闻信息超链接
     * @name  XWXX_CLJ
     * @type  string
     */
    public $XWXX_CLJ;
    
    /**
     * 属性  新闻信息内容
     * @name  XWXX_NR
     * @type  string
     */
    public $XWXX_NR;
    
    /**
     * 属性  新闻信息图片
     * @name  XWXX_TP
     * @type  string
     * @note  按照指定分辨率自动裁切图片
     */
    public $XWXX_TP;
    #endregion 实体固有属性
        
    #region 获取外键实体函数
    
    /**
     * 外键实体：新闻栏目(XWLM)
     * @name  getXWLM
     * @return  XWLM 获取XWLM外键实体对象
     */
    public function getXWLM()
    {
        //此处语句需要修改SchemaTools.UseParams工具函数
        $xwlm = new XWLM();
        $xwlm->fetch($this->XWLM_BH );
        return $xwlm;
    }
    #endregion 获取外键实体函数    
    
    #region 校验数据
    /**
     * @note  在进行数据更新和数据插入之前,对对象的属性进行服务端验证
     * @return  string 返回空字符串表示通过验证，否则直接返回错误信息，多条错误用;（半角分号）分隔多条错误
     */
    public function validate()
    {
    
        $result = array();
            
        #region 新闻信息编号验证   
        $flag=true;
        //编号最大长度为50
        if($flag && (count(unpack('C*',$this->XWXX_BH )) > 50)){ 
            $flag=false;
            array_push($result,'编号最大长度为50'); 
        }
        //编号必须填写
        if($flag && (is_null($this->XWXX_BH) || $this->XWXX_BH==='')){ 
            array_push($result,'编号必须填写'); 
        }
        #endregion 新闻信息编号验证   
            
        #region 新闻栏目编号验证   
        $flag=true;
        //编号最大长度为50
        if($flag && (count(unpack('C*',$this->XWLM_BH )) > 50)){ 
            $flag=false;
            array_push($result,'编号最大长度为50'); 
        }
        //编号必须填写
        if($flag && (is_null($this->XWLM_BH) || $this->XWLM_BH==='')){ 
            array_push($result,'编号必须填写'); 
        }
        #endregion 新闻栏目编号验证   
            
        #region 新闻信息标题验证   
        $flag=true;
        //标题最大长度为200
        if($flag && (count(unpack('C*',$this->XWXX_BT )) > 200)){ 
            $flag=false;
            array_push($result,'标题最大长度为200'); 
        }
        //标题必须填写
        if($flag && (is_null($this->XWXX_BT) || $this->XWXX_BT==='')){ 
            array_push($result,'标题必须填写'); 
        }
        #endregion 新闻信息标题验证   
            
        #region 新闻信息摘要验证   
        $flag=true;
        //摘要最大长度为500
        if($flag && (count(unpack('C*',$this->XWXX_ZY )) > 500)){ 
            $flag=false;
            array_push($result,'摘要最大长度为500'); 
        }
        //摘要必须填写
        if($flag && (is_null($this->XWXX_ZY) || $this->XWXX_ZY==='')){ 
            array_push($result,'摘要必须填写'); 
        }
        #endregion 新闻信息摘要验证   
            
        #region 新闻信息日期验证   
        $flag=true;
        //日期最大长度为50
        if($flag && (count(unpack('C*',$this->XWXX_RQ )) > 50)){ 
            $flag=false;
            array_push($result,'日期最大长度为50'); 
        }
        //日期必须填写
        if($flag && (is_null($this->XWXX_RQ) || $this->XWXX_RQ==='')){ 
            array_push($result,'日期必须填写'); 
        }
        #endregion 新闻信息日期验证   
            
        #region 新闻信息状态验证   
        $flag=true;
        //状态最大长度为50
        if($flag && (count(unpack('C*',$this->XWXX_ZT )) > 50)){ 
            $flag=false;
            array_push($result,'状态最大长度为50'); 
        }
        //状态必须填写
        if($flag && (is_null($this->XWXX_ZT) || $this->XWXX_ZT==='')){ 
            array_push($result,'状态必须填写'); 
        }
        #endregion 新闻信息状态验证   
            
        #region 新闻信息类型验证   
        $flag=true;
        //类型最大长度为50
        if($flag && (count(unpack('C*',$this->XWXX_LX )) > 50)){ 
            $flag=false;
            array_push($result,'类型最大长度为50'); 
        }
        //类型必须填写
        if($flag && (is_null($this->XWXX_LX) || $this->XWXX_LX==='')){ 
            array_push($result,'类型必须填写'); 
        }
        #endregion 新闻信息类型验证   
            
        #region 新闻信息超链接验证   
        $flag=true;
        //超链接最大长度为500
        if($flag && (count(unpack('C*',$this->XWXX_CLJ )) > 500)){ 
            array_push($result,'超链接最大长度为500'); 
        }
        #endregion 新闻信息超链接验证   
            
        #region 新闻信息图片验证   
        $flag=true;
        //图片最大长度为500
        if($flag && (count(unpack('C*',$this->XWXX_TP )) > 500)){ 
            array_push($result,'图片最大长度为500'); 
        }
        #endregion 新闻信息图片验证   
        return  implode("<br/>", $result);
    }
    #endregion 校验数据
    
    #region 插入数据
    /**
     * @note  插入数据
     * @return string 返回空字符串表示操作成功，其它情况返回的是错误提示信息
     */
    public function insert()
    {
        //数据校验
        $message = $this->validate();
        if (!empty($message)) {
            return $message;
        }
        
        //以下属性不允许用户直接操作
                
        //准备sql语句
        $sql = "INSERT INTO XWXX(
                        XWXX_BH
                        ,XWLM_BH
                        ,XWXX_BT
                        ,XWXX_ZY
                        ,XWXX_RQ
                        ,XWXX_ZT
                        ,XWXX_LX
                        ,XWXX_CLJ
                        ,XWXX_NR
                        ,XWXX_TP
                       )
                 VALUES(
                        :XWXX_BH
                        ,:XWLM_BH
                        ,:XWXX_BT
                        ,:XWXX_ZY
                        ,:XWXX_RQ
                        ,:XWXX_ZT
                        ,:XWXX_LX
                        ,:XWXX_CLJ
                        ,:XWXX_NR
                        ,:XWXX_TP
                       )";
        //创建pdo对象，并绑定执行参数               
        $pdo = new PDO(C("AUTO_GENERATOR_DB_DSN"), C("AUTO_GENERATOR_DB_USER"), C("AUTO_GENERATOR_DB_PWD"));       
        $stmt = $pdo->prepare($sql);
        //准备sql语句所需参数
        $stmt->bindParam(':XWXX_BH',$this->XWXX_BH); //新闻信息编号
        $stmt->bindParam(':XWLM_BH',$this->XWLM_BH); //新闻栏目编号
        $stmt->bindParam(':XWXX_BT',$this->XWXX_BT); //新闻信息标题
        $stmt->bindParam(':XWXX_ZY',$this->XWXX_ZY); //新闻信息摘要
        $stmt->bindParam(':XWXX_RQ',$this->XWXX_RQ); //新闻信息日期
        $stmt->bindParam(':XWXX_ZT',$this->XWXX_ZT); //新闻信息状态
        $stmt->bindParam(':XWXX_LX',$this->XWXX_LX); //新闻信息类型
        $stmt->bindParam(':XWXX_CLJ',$this->XWXX_CLJ); //新闻信息超链接
        $stmt->bindParam(':XWXX_NR',$this->XWXX_NR); //新闻信息内容  
        $stmt->bindParam(':XWXX_TP',$this->XWXX_TP); //新闻信息图片
        $stmt->execute();
        if ($stmt->rowCount() === 1) {
            return "";
        }
        if (strpos($stmt->errorInfo()[2], "重复", 0)) {
            return "重复项添加失败";
        }
        if (strpos($stmt->errorInfo()[2], "截断", 0)) {
            return "数据超长";
        }
        return $stmt->errorInfo()[2];
    }
    #endregion 插入数据
    
    #region 更新数据
    /**
     * @note  更新数据
     * @param string $xwxx_bh_ora 拟更新的XWXX实体主键值，如果为空，表示更新当前实体.
     * @return string 返回空字符串表示操作成功，其它情况返回的是错误提示信息
     */ 
    public function update($xwxx_bh_ora = null )
    {
        //数据校验
        $message = $this->validate();
        if (!empty($message)) {
            return $message;
        }
        
        //用户操作记录,以下属性不允许用户直接操作
        
        //准备sql语句
        $sql = "UPDATE XWXX SET 
                    XWXX_BH=:XWXX_BH
                    ,XWLM_BH=:XWLM_BH
                    ,XWXX_BT=:XWXX_BT
                    ,XWXX_ZY=:XWXX_ZY
                    ,XWXX_RQ=:XWXX_RQ
                    ,XWXX_ZT=:XWXX_ZT
                    ,XWXX_LX=:XWXX_LX
                    ,XWXX_CLJ=:XWXX_CLJ
                    ,XWXX_NR=:XWXX_NR
                    ,XWXX_TP=:XWXX_TP
                WHERE
                    XWXX_BH=:XWXX_BH_ORA
                    ";
        
        //准备pdo对象
        $pdo = new PDO(C("AUTO_GENERATOR_DB_DSN"), C("AUTO_GENERATOR_DB_USER"), C("AUTO_GENERATOR_DB_PWD"));
        $stmt = $pdo->prepare($sql);
        //准备sql语句所需参数
        $stmt->bindParam(':XWXX_BH_ORA',empty($xwxx_bh_ora)?$this->XWXX_BH:$xwxx_bh_ora); //新闻信息编号
        $stmt->bindParam(':XWXX_BH',$this->XWXX_BH); //新闻信息编号
        $stmt->bindParam(':XWLM_BH',$this->XWLM_BH); //新闻栏目编号
        $stmt->bindParam(':XWXX_BT',$this->XWXX_BT); //新闻信息标题
        $stmt->bindParam(':XWXX_ZY',$this->XWXX_ZY); //新闻信息摘要
        $stmt->bindParam(':XWXX_RQ',$this->XWXX_RQ); //新闻信息日期
        $stmt->bindParam(':XWXX_ZT',$this->XWXX_ZT); //新闻信息状态
        $stmt->bindParam(':XWXX_LX',$this->XWXX_LX); //新闻信息类型
        $stmt->bindParam(':XWXX_CLJ',$this->XWXX_CLJ); //新闻信息超链接
        $stmt->bindParam(':XWXX_NR',$this->XWXX_NR); //新闻信息内容  
        $stmt->bindParam(':XWXX_TP',$this->XWXX_TP); //新闻信息图片
        $stmt->execute();
        if ($stmt->rowCount() === 1) {
            return "";
        }
        return $stmt->errorInfo()[2];
    }
    #endregion 更新数据
    
    #region 删除数据 
    /**
     * @note  根据主键信息删除XWXX对象
     * @param  string $xwxx_bh_ora 拟删除的XWXX实体主键值，如果为空，表示删除当前实体.
     * @return string 返回空字符串表示操作成功，其它情况返回的是错误提示信息
     */ 
    public function delete($xwxx_bh_ora = null )
    {
        
        //准备sql语句
        $sql = "Delete From XWXX where 
                    XWXX_BH=:XWXX_BH_ORA
                    ";
         //执行sql语句
        $pdo = new PDO(C("AUTO_GENERATOR_DB_DSN"), C("AUTO_GENERATOR_DB_USER"), C("AUTO_GENERATOR_DB_PWD"));
        $stmt = $pdo->prepare($sql);
        //准备sql语句所需参数
        if($xwxx_bh_ora==null){
            $xwxx_bh_ora=$this->XWXX_BH;
        }
        $stmt->bindParam(':XWXX_BH_ORA',empty($xwxx_bh_ora)?$this->XWXX_BH:$xwxx_bh_ora); //新闻信息编号
        $stmt->execute();
        
        if ($stmt->rowCount() === 1) {
            return "";
        }
        //需要根据不同的数据库检查不同的返回值
        if (strpos($stmt->errorInfo()[2], "约束", 0)) {
            return "存在依赖的相关信息，不能进行删除";
        }
        return $stmt->errorInfo()[2];                    
    }
    #endregion 删除数据
    
    #region 获取单个对象 
    /**
     * @note  根据主键信息获取单个XWXX对象
     * @param  string $xwxx_bh_ora 拟获取的XWXX实体主键值，如果为空，表示按照当前实体的主键属性重新获取实体.
     * @return string 返回空字符串表示操作成功，其它情况返回的是错误提示信息
     */ 
    public function fetch($xwxx_bh_ora = null )
    {
        
        //准备sql语句所需参数
        $params[":XWXX_BH_ORA"] = is_null($xwxx_bh_ora) ? $this->XWXX_BH : $xwxx_bh_ora ; //新闻信息_编号
        
        //准备sql语句
        $sql = "SELECT 
                    XWXX_BH
                    ,XWLM_BH
                    ,XWXX_BT
                    ,XWXX_ZY
                    ,XWXX_RQ
                    ,XWXX_ZT
                    ,XWXX_LX
                    ,XWXX_CLJ
                    ,XWXX_NR
                    ,XWXX_TP
                  FROM XWXX 
                  WHERE
                    XWXX_BH = :XWXX_BH_ORA
                ";
        
        //  执行sql语句
        $pdo = new PDO(C("AUTO_GENERATOR_DB_DSN"), C("AUTO_GENERATOR_DB_USER"), C("AUTO_GENERATOR_DB_PWD"));
        $stmt = $pdo->prepare($sql);
        $stmt->execute($params);
        $result = $stmt->fetch(PDO::FETCH_ASSOC);
        if ($result !== false) {
            $this->XWXX_BH = is_null($result["XWXX_BH"] ) ? '' : $result["XWXX_BH"];
            $this->XWLM_BH = is_null($result["XWLM_BH"] ) ? '' : $result["XWLM_BH"];
            $this->XWXX_BT = is_null($result["XWXX_BT"] ) ? '' : $result["XWXX_BT"];
            $this->XWXX_ZY = is_null($result["XWXX_ZY"] ) ? '' : $result["XWXX_ZY"];
            $this->XWXX_RQ = is_null($result["XWXX_RQ"] ) ? '' : $result["XWXX_RQ"];
            $this->XWXX_ZT = is_null($result["XWXX_ZT"] ) ? '' : $result["XWXX_ZT"];
            $this->XWXX_LX = is_null($result["XWXX_LX"] ) ? '' : $result["XWXX_LX"];
            $this->XWXX_CLJ = is_null($result["XWXX_CLJ"] ) ? '' : $result["XWXX_CLJ"];
            if(is_resource($result['XWXX_NR'])){
                 $this->XWXX_NR=stream_get_contents($result['XWXX_NR']);
            }
            else{
                $this->XWXX_NR=$result['XWXX_NR'];
            }
            $this->XWXX_TP = is_null($result["XWXX_TP"] ) ? '' : $result["XWXX_TP"];
            return "";
        } else {
            return "要获取的对象不存在";
        }
    }
    #endregion 获取单个对象 
    
    #region 尝试获取单个对象，并返回获取的对象
    /**
     * @note  尝试获取单个XWXX对象，并返回获取的对象
     * @param  string $xwxx_bh_ora 拟获取的XWXX实体主键值，如果为空，表示按照当前实体的主键属性重新获取实体.
     * @return XWXX 返回null表示操作失败，其它情况返回要获取的对象
     */
    public static function create($xwxx_bh_ora )
    {
        //准备sql语句所需参数
        $params[":XWXX_BH_ORA"] = $xwxx_bh_ora ; //新闻信息_编号
        
        //准备sql语句
        $sql = "SELECT 
                    XWXX_BH
                    ,XWLM_BH
                    ,XWXX_BT
                    ,XWXX_ZY
                    ,XWXX_RQ
                    ,XWXX_ZT
                    ,XWXX_LX
                    ,XWXX_CLJ
                    ,XWXX_NR
                    ,XWXX_TP
                  FROM XWXX 
                  WHERE
                    XWXX_BH = :XWXX_BH_ORA
                ";
        
        //  执行sql语句
        $pdo = new PDO(C("AUTO_GENERATOR_DB_DSN"), C("AUTO_GENERATOR_DB_USER"), C("AUTO_GENERATOR_DB_PWD"));
        $stmt = $pdo->prepare($sql);
        $stmt->execute($params);
        $result = $stmt->fetch(PDO::FETCH_ASSOC);
        $xwxx = new XWXX();
        if ($result !== false) {
            $xwxx->XWXX_BH = is_null($result["XWXX_BH"] ) ? '' : $result["XWXX_BH"];
            $xwxx->XWLM_BH = is_null($result["XWLM_BH"] ) ? '' : $result["XWLM_BH"];
            $xwxx->XWXX_BT = is_null($result["XWXX_BT"] ) ? '' : $result["XWXX_BT"];
            $xwxx->XWXX_ZY = is_null($result["XWXX_ZY"] ) ? '' : $result["XWXX_ZY"];
            $xwxx->XWXX_RQ = is_null($result["XWXX_RQ"] ) ? '' : $result["XWXX_RQ"];
            $xwxx->XWXX_ZT = is_null($result["XWXX_ZT"] ) ? '' : $result["XWXX_ZT"];
            $xwxx->XWXX_LX = is_null($result["XWXX_LX"] ) ? '' : $result["XWXX_LX"];
            $xwxx->XWXX_CLJ = is_null($result["XWXX_CLJ"] ) ? '' : $result["XWXX_CLJ"];
            if(is_resource($result['XWXX_NR'])){
                 $xwxx->XWXX_NR=stream_get_contents($result['XWXX_NR']);
            }
            else{
                $xwxx->XWXX_NR=$result['XWXX_NR'];
            }
            $xwxx->XWXX_TP = is_null($result["XWXX_TP"] ) ? '' : $result["XWXX_TP"];
            return $xwxx;
        } else {
            return null;
        }
    }
    #endregion 根据主键创建对象（如果存在记录自动进行填充）
    
    #region 获取一组XWXX信息对象
    /**
     * @note 获取一组用户信息信息对象.
     * @param array $param 参数数组
     * @param int $pageSize 分页尺寸
     * @param int $pageIndex 当前页
     * @param string $orderby 排序语句（需要包括 order by ）
     * @param string $sql 用户自定义使用的SQL语句
     * @return array 带分页信息的对象数组
     */
    public static function query($param = array() , $pageSize = 0 , $pageIndex = 1 , $orderby="" , $sql= "")
    {
    
        #region 声明和处理常用变量
        
        //生成返回值变量
        $result = array();
               
        //处理sql语句默认值
        if(empty($sql)){
            $sql ="select XWXX.* from XWXX ";
        }
        
        //自动过滤掉返回结果集中的超文本字段
        $sqlreplace ='
                    XWXX.XWXX_BH
                    ,XWXX.XWLM_BH
                    ,XWXX.XWXX_BT
                    ,XWXX.XWXX_ZY
                    ,XWXX.XWXX_RQ
                    ,XWXX.XWXX_ZT
                    ,XWXX.XWXX_LX
                    ,XWXX.XWXX_CLJ
                    ,XWXX.XWXX_TP
                     ';
        $sql = str_replace( 'XWXX.*', $sqlreplace , $sql);
        
        //处理传入的参数
        $params = array();
        foreach ($param as $key => $value) {
            if($value == null || $value == ""){
                continue;
            }
            $params[":" . strtoupper(str_replace(":", "", $key))] = $value;
        }
    
        //排序条件
        if (empty($orderby))
        {
            $orderby = "order by XWXX.XWXX_BH";
        }
                
        $where = " WHERE 1 = 1 ";
        
        // XWXX表的模糊查询条件
        if (array_key_exists(':MHCX',$params) )
        {
            $where.=" and (XWXX.XWXX_BT + '_' + XWXX.XWXX_ZY) like '%' + :MHCX + '%' ";
        }
        
        // XWLM_BH精确查询条件
        if (array_key_exists(':XWLM_BH',$params) )
        {
            $where.=" and XWXX.XWLM_BH = :XWLM_BH ";
        }
        
        // XWXX_ZT精确查询条件
        if (array_key_exists(':XWXX_ZT',$params) )
        {
            $where.=" and XWXX.XWXX_ZT = :XWXX_ZT ";
        }
        
        // XWXX_RQ区段查询(前空后不空)
        if (!array_key_exists(':XWXX_RQBEGIN',$params) && array_key_exists(':XWXX_RQEND',$params) )
        {
            $where.="and XWXX.XWXX_RQ = :XWXX_RQEND ";
        }
        
        // XWXX_RQ区段查询(前不空后空)
        if (array_key_exists(':XWXX_RQBEGIN',$params) && !array_key_exists(':XWXX_RQEND',$params) )
        {
            $where.="and XWXX.XWXX_RQ = :XWXX_RQBEGIN ";
        }
        
        // XWXX_RQ区段查询(前大于后)
        if (array_key_exists(':XWXX_RQBEGIN',$params) && array_key_exists(':XWXX_RQEND',$params) && strcmp($params[':XWXX_RQBEGIN'], $params[':XWXX_RQEND']) >0  )
        {
            $where.="and ( XWXX.XWXX_RQ <= :XWXX_RQBEGIN and XWXX.XWXX_RQ >= :XWXX_RQEND )";
        }
        
        // XWXX_RQ区段查询(前小于后)
        if (array_key_exists(':XWXX_RQBEGIN',$params) && array_key_exists(':XWXX_RQEND',$params) && strcmp($params[':XWXX_RQBEGIN'], $params[':XWXX_RQEND']) <0  )
        {
            $where.="and ( XWXX.XWXX_RQ >= :XWXX_RQBEGIN and XWXX.XWXX_RQ <= :XWXX_RQEND )";
        }
        
        // XWXX_RQ区段查询(前后相同)
        if (array_key_exists(':XWXX_RQBEGIN',$params) && array_key_exists(':XWXX_RQEND',$params) && strcmp($params[':XWXX_RQBEGIN'], $params[':XWXX_RQEND']) == 0  )
        {
            $where.="and (XWXX.XWXX_RQ = :XWXX_RQBEGIN and XWXX.XWXX_RQ = :XWXX_RQEND)";
        }
        #endregion 声明和处理常用变量
        
        #region 获取记录总数和分页相关信息
        
        $pdo = new PDO(C("AUTO_GENERATOR_DB_DSN"), C("AUTO_GENERATOR_DB_USER"), C("AUTO_GENERATOR_DB_PWD"));
        $stmt = $pdo->prepare("select count(*) from ($sql $where) TTT");
        $stmt->execute($params);
        $result['TotalCount'] = intval($stmt->fetch()[0]);

        if($pageSize === 0){
            $result['TotalPages'] = 1;
            $result['PageIndex'] = 1;
            $result['PageSize'] = $result[0];
            $beginRow= 1;
            $endRow = $result['TotalCount'];    
        }
        else{
            $result['PageSize'] = $pageSize;
            $result['TotalPages'] = intval((($result['TotalCount'] - 1) / $result['PageSize'])) + 1;
            $result['PageIndex'] = min(max(1,$pageIndex), $result['TotalPages']);
            $beginRow = ($result['PageIndex'] - 1) * $result['PageSize'] + 1;
            $endRow = $result['PageIndex'] * $result['PageSize'];
        }
        $result['HasPreviousPage'] = $result['PageIndex'] > 1;
        $result['HasNextPage'] = $result['PageIndex'] < $result['TotalPages'];
        $result['IsFirstPage'] = $result['PageIndex'] == 1;
        $result['IsLastPage'] = $result['PageIndex'] == $result['TotalPages'];
        $result['BoolPage'] = $pageSize == 0;
        #endregion 获取记录总数和分页相关信息
        
        #region 查询数据库并返回结果
        $result['DataList'] = array();
        //SQLServer获取结果集
        $sql="SELECT ROW_NUMBER() over($orderby) as rownumber ,".substr($sql,6);
        $sql = "SELECT * FROM ( 
                        $sql $where
                    ) as TTT where rownumber between $beginRow and $endRow ";
        $stmt = $pdo->prepare($sql);
        $stmt->execute($params);
        while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
            $temp=new XWXX();
            foreach($row as $key=>$value){
                $temp->$key = $value;
            }
            array_push($result['DataList'],$temp);
        }
        return $result;
        #endregion 查询数据库并返回结果
    }
    #endregion 获取XWXX信息对象DataResponse
    
    #region 获取XWXX子表表名数组
    /**
     * @note 返回子表表名数组.
     * @return array 子表表名数组
     */
    public static function subtables()
    {
        //生成返回值变量
        $result = array();
        
        
        return $result;
    }
    #endregion 获取XWXX子表表名数组
    #endregion 自动生成代码
   
    #endregion 扩展属性

}
